// 获取用户基本信息的模块
// 导入数据库操作模块
const db = require('../db/index')
// 导入处理密码的模块
const bcrypt = require('bcryptjs')

// 获取用户基本信息的处理函数
exports.getUserInfo = (req, res) => {
    // 定义查询用户信息的 SQL 语句
    const sql = `select id, username, nickname, email, user_pic from ev_users where id=?`;
    // 调用 db.query() 执行 SQL 语句
    db.query(sql, req.user.id, (err, results) => {
        // 执行 SQL 语句失败
        if(err) return res.cc('获取用户信息失败！')
        // 执行 SQL 语句成功，但是查询的结果可能为空
        if(results.length !== 1) return res.cc('获取用户信息失败！')

        // 用户信息成功
        res.send({
            status: 0,
            message: '获取用户信息成功！',
            data: results[0],
        })
    })
}

// 更新用户基本信息的处理函数
exports.updateUserInfo = (req, res) => {
    // 定义待执行的 SQL 语句
    const sql = 'update ev_users set ? where id=?'
    // 调用 d.query() 执行 SQL 语句并传递参数
    db.query(sql, [req.body, req.body.id], (err, results) => {
        // 执行 SQL语句失败
        if(err) return res.cc(err)
        // 执行 SQl 语句成功，但是影响行数 ！== 1
        if(results.affectedRows !== 1) return res.cc('更新用户的基本信息是失败！！')
        // 成功
        res.cc('更新用户信息成功！！',0)
    })
   
}

// 更新用户密码的处理函数
exports.updatePassword = (req,res) => {
    // 待执行的 SQL 的语句,根据 id 查询用户信息的SQL语句
    const sql = 'select * from ev_users where id=?'
    // 根据 id 查询用户的信息的 SQL 语句
    db.query(sql, req.user.id, (err, results) => {
        // SQL语句执行失败
        if(err) return res.cc(err)
        // 判断结果是否存在
        if(results.length !== 1) return res.cc('用户不存在！！')

        // TODO：判断用户输入的就密码是否正常
        const compareResult = bcrypt.compareSync(req.body.oldPwd, results[0].password)
        if(!compareResult) return res.cc('旧密码错误！！')

        // 更新数据库中的密码
        // 更新数据库密码的 SQL 语句
        const sql = 'update ev_users set password=? where id=?'
        // 对新密码进行加密处理
        const newPwd = bcrypt.hashSync(req.body.newPwd, 10)
        // 调用 db.query() 执行 SQl语句
        db.query(sql , [newPwd, req.user.id], (err, results) => {
            // SQL语句执行失败
            if(err) return res.cc(err)
            // 判断影响的行数
            if(results.affectedRows !== 1) return res.cc('更新密码失败！')
            // 成功
            res.cc('更新成功！', 0)
        })
    })
    
}

exports.updateAvatar = (req,res) => {
    // 定义更新头像的 SQL 语句
    const sql = 'update ev_users set user_pic=? where id=?'
    // 调用 db.query() 执行 SQL 语句
    db.query(sql, [req.body.avatar, req.user.id], (err,results) => {
        // SQL 执行失败
        if(err) return res.cc(err)
        // 执行 SQL 语句成功，但是影响行数不等于1
        if(results.affectedRows !== 1) return res.cc('更新头像失败！')
        // 更新用户头像成功
        return res.cc('更新用户头像成功！',0)
    })
}